<script setup lang="ts">
import { ref, reactive, computed } from 'vue'
import { Search } from '@element-plus/icons-vue'
import { useRouter } from 'vue-router'

const searchQuery = ref('')
const router = useRouter()

const faqCategories = reactive([
  {
    title: '常规问题',
    icon: '❓',
    faqs: [
      {
        question: '什么是水印工具？',
        answer: '水印工具是一款专业的图片处理软件，可以帮助您快速为图片添加或去除水印，保护您的图片版权或移除不需要的标记。'
      },
      {
        question: '使用水印工具需要安装软件吗？',
        answer: '不需要，我们的水印工具是一个基于网页的应用程序，您只需要一个现代浏览器即可使用全部功能，无需下载或安装任何软件。'
      },
      {
        question: '水印工具支持哪些图片格式？',
        answer: '目前我们支持JPG、PNG、WEBP等常见图片格式。专业版和企业版用户可以使用更多格式，包括TIFF、BMP等。'
      },
      {
        question: '我可以在手机上使用水印工具吗？',
        answer: '是的，我们的网站采用响应式设计，可以在手机、平板和电脑等各种设备上使用。'
      }
    ]
  },
  {
    title: '账户与付费',
    icon: '💰',
    faqs: [
      {
        question: '如何创建账户？',
        answer: '点击网站右上角的"注册"按钮，填写您的邮箱、用户名和密码即可创建账户。您也可以通过第三方账号（如Google、Facebook）一键登录。'
      },
      {
        question: '忘记密码怎么办？',
        answer: '在登录页面点击"忘记密码"，输入您的注册邮箱，我们会发送重置密码的链接到您的邮箱。'
      },
      {
        question: '如何升级到专业版？',
        answer: '登录您的账户后，访问"价格方案"页面，选择适合您的方案，按照页面提示完成支付即可升级。'
      },
      {
        question: '支持哪些支付方式？',
        answer: '我们支持支付宝、微信支付、银联以及主流信用卡（Visa、Mastercard等）。'
      },
      {
        question: '如何取消订阅？',
        answer: '登录账户后，进入"个人中心"-"我的订阅"，点击"取消订阅"按钮即可。取消后，您可以继续使用当前订阅周期内的服务，直到订阅期结束。'
      }
    ]
  },
  {
    title: '功能使用',
    icon: '⚙️',
    faqs: [
      {
        question: '如何添加水印？',
        answer: '上传您的图片后，选择"添加水印"功能，然后选择水印类型（文字或图片），设置位置、透明度等参数，点击"应用"即可。'
      },
      {
        question: '如何批量处理图片？',
        answer: '在工具中心页面，一次性上传多张图片（免费用户最多5张，专业版无限制），设置好水印参数后，点击"批量处理"按钮即可同时处理所有图片。'
      },
      {
        question: '处理后的图片质量会下降吗？',
        answer: '我们使用先进的算法，尽可能保持原图的质量。默认情况下，处理后的图片质量不会有明显下降。专业版和企业版用户可以选择无损处理选项。'
      },
      {
        question: '水印可以放在图片的任何位置吗？',
        answer: '是的，您可以通过拖拽或输入精确坐标来将水印放置在图片的任何位置。专业版用户还可以设置水印的旋转角度和平铺模式。'
      },
      {
        question: '可以去除任何水印吗？',
        answer: '我们的水印去除功能对大多数简单水印有较好的效果。复杂水印或与图片紧密融合的水印可能效果有限。企业版用户可以使用我们的高级AI去水印算法，对复杂水印也有较好的处理能力。'
      }
    ]
  },
  {
    title: '隐私与安全',
    icon: '🔒',
    faqs: [
      {
        question: '我上传的图片安全吗？',
        answer: '是的，您的图片安全是我们的首要任务。所有图片处理都在您的浏览器中完成，不会上传到我们的服务器。对于需要服务器处理的操作，我们采用加密传输，处理完成后立即删除您的原始图片。'
      },
      {
        question: '你们会收集我的哪些信息？',
        answer: '我们只收集必要的信息用于提供服务，如账户信息、使用统计等。我们不会未经您的许可收集或分享您的个人信息。详细内容请参阅我们的隐私政策。'
      },
      {
        question: '如何确保账户安全？',
        answer: '我们建议使用强密码并启用双因素认证以增强账户安全。我们也会监控异常登录活动并通知您。'
      }
    ]
  },
  {
    title: '技术支持',
    icon: '📞',
    faqs: [
      {
        question: '遇到问题如何获取帮助？',
        answer: '您可以通过网站底部的"联系我们"发送邮件，或在工作时间通过在线客服获得帮助。专业版和企业版用户可享受优先支持服务。'
      },
      {
        question: '有使用教程吗？',
        answer: '是的，我们提供详细的文字和视频教程，您可以在"帮助中心"找到。我们也会定期在博客更新功能介绍和使用技巧。'
      },
      {
        question: '支持哪些浏览器？',
        answer: '我们支持所有现代浏览器的最新版本，包括Chrome、Firefox、Safari、Edge等。为了获得最佳体验，我们建议使用Chrome浏览器。'
      },
      {
        question: '处理大图片时网页很慢怎么办？',
        answer: '处理大图片需要较多的计算资源。建议关闭其他不必要的标签页，确保电脑有足够的内存。专业版和企业版用户可以使用我们的云处理功能，速度更快且不占用本地资源。'
      }
    ]
  }
])

const filteredFaqs = computed(() => {
  if (!searchQuery.value.trim()) return faqCategories
  
  const query = searchQuery.value.toLowerCase().trim()
  
  return faqCategories.map(category => {
    const filteredItems = category.faqs.filter(item => 
      item.question.toLowerCase().includes(query) || 
      item.answer.toLowerCase().includes(query)
    )
    
    return {
      ...category,
      faqs: filteredItems
    }
  }).filter(category => category.faqs.length > 0)
})

const hasResults = computed(() => {
  return filteredFaqs.value.some(category => category.faqs.length > 0)
})

const clearSearch = () => {
  searchQuery.value = ''
}

const navigateTo = (path) => {
  console.log('正在导航到:', path) // 添加调试日志
  router.push(path)
}

const goToLogin = () => {
  window.location.href = '/auth/login'
}

const goToRegister = () => {
  window.location.href = '/auth/register'
}
</script>

<template>
  <div class="faq-page">
    <!-- 头部区域 -->
    <div class="header-section">
      <div class="container">
        <div class="header-content">
          <h1 class="animate-fade-up">常见问题</h1>
          <p class="animate-fade-up" style="--delay: 0.2s">找到您关心的问题的答案</p>
          
          <!-- 搜索框 -->
          <div class="search-box animate-fade-up" style="--delay: 0.3s">
            <el-input
              v-model="searchQuery"
              placeholder="输入关键词搜索问题..."
              clearable
              class="search-input"
            >
              <template #prefix>
                <el-icon class="search-icon"><Search /></el-icon>
              </template>
            </el-input>
          </div>
        </div>
      </div>
      <div class="header-wave">
        <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1440 320" preserveAspectRatio="none">
          <path fill="#ffffff" fill-opacity="1" d="M0,96L48,112C96,128,192,160,288,186.7C384,213,480,235,576,229.3C672,224,768,192,864,165.3C960,139,1056,117,1152,122.7C1248,128,1344,160,1392,176L1440,192L1440,320L1392,320C1344,320,1248,320,1152,320C1056,320,960,320,864,320C768,320,672,320,576,320C480,320,384,320,288,320C192,320,96,320,48,320L0,320Z"></path>
        </svg>
      </div>
    </div>

    <!-- 主要内容区域 -->
    <div class="container">
      <!-- 无结果提示 -->
      <div v-if="searchQuery && !hasResults" class="no-results animate-fade-up">
        <div class="no-results-icon">❓</div>
        <h2>未找到相关问题</h2>
        <p>尝试使用其他关键词，或浏览下方的所有问题</p>
        <el-button type="primary" @click="clearSearch" class="btn-clear">清除搜索</el-button>
      </div>

      <!-- FAQ类别和问题 -->
      <div v-else class="faq-content">
        <div v-for="(category, index) in filteredFaqs" :key="category.title" class="faq-category animate-fade-up" :style="`--delay: ${0.4 + index * 0.1}s`">
          <div class="category-header">
            <div class="category-icon">{{ category.icon }}</div>
            <h2>{{ category.title }}</h2>
          </div>
          
          <el-collapse>
            <el-collapse-item v-for="(item, i) in category.faqs" :key="i" :title="item.question" :name="i">
              <div class="faq-answer">{{ item.answer }}</div>
            </el-collapse-item>
          </el-collapse>
        </div>
      </div>

      <!-- 联系支持 -->
      <div class="contact-support animate-fade-up" style="--delay: 0.9s">
        <div class="support-content">
          <h2>没有找到您的问题？</h2>
          <p>我们的客服团队随时为您解答任何疑问</p>
          <el-button type="primary" class="btn-contact">联系我们</el-button>
        </div>
      </div>
    </div>
  </div>
</template>

<style scoped>
/* 强制修改头部区域样式 */
.faq-page {
  padding-top: 64px !important; /* 添加顶部内边距，与导航栏高度匹配 */
  min-height: 100vh;
  background-color: var(--bg-color);
}

/* 头部区域样式 */
.header-section {
  position: relative;
  background: var(--primary-gradient);
  padding: 3rem 0 8rem !important; /* 减少顶部内边距 */
  color: white;
  overflow: hidden;
  z-index: 1; /* 降低z-index，确保不会覆盖导航栏 */
  margin-top: 20px;
}

.header-content {
  text-align: center;
  max-width: 800px;
  margin: 0 auto;
  padding: 0 1rem;
}

.header-content h1 {
  font-size: clamp(1.8rem, 5vw, 2.5rem);
  font-weight: 700;
  margin-bottom: clamp(0.5rem, 2vw, 1rem);
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.header-content p {
  font-size: clamp(0.9rem, 2vw, 1.1rem);
  opacity: 0.9;
  margin-bottom: 2rem;
}

.header-wave {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 80px;
  overflow: hidden;
  line-height: 0;
}

.header-wave svg {
  width: 100%;
  height: 100%;
}

/* 搜索框样式 */
.search-box {
  max-width: 600px;
  margin: 0 auto;
}

.search-input {
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
  border-radius: 100px;
  overflow: hidden;
}

.search-input :deep(.el-input__wrapper) {
  padding-left: 20px;
  border-radius: 100px;
}

.search-input :deep(.el-input__inner) {
  font-size: 1rem;
  height: 50px;
}

.search-icon {
  font-size: 18px;
  color: #999;
}

/* 主内容区布局 */
.container {
  width: 100%;
  max-width: var(--container-max-width, 1400px);
  margin: 100px auto 0;
  padding: 0 clamp(1rem, 3vw, 2rem);
}

/* FAQ内容区域 */
.faq-content {
  margin-top: -4rem !important; /* 调整内容位置 */
  position: relative;
  z-index: var(--z-content);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 600px), 1fr));
  gap: clamp(1.5rem, 4vw, 2.5rem);
  margin-bottom: 3rem;
}

.faq-category {
  background-color: white;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  overflow: hidden;
}

.category-header {
  display: flex;
  align-items: center;
  padding: 1.5rem;
  border-bottom: 1px solid var(--border-color);
}

.category-icon {
  font-size: 1.8rem;
  margin-right: 1rem;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: rgba(19, 194, 194, 0.1);
  border-radius: 12px;
}

.category-header h2 {
  margin: 0;
  font-size: 1.25rem;
  color: var(--text-color);
}

.faq-category :deep(.el-collapse) {
  border: none;
}

.faq-category :deep(.el-collapse-item__header) {
  padding: 1rem 1.5rem;
  font-size: 1rem;
  font-weight: 500;
  color: var(--text-color);
  border-bottom: 1px solid var(--border-color);
}

.faq-category :deep(.el-collapse-item__content) {
  padding: 1rem 1.5rem 1.5rem;
}

.faq-answer {
  color: var(--text-secondary);
  line-height: 1.6;
}

/* 无结果提示 */
.no-results {
  text-align: center;
  background-color: white;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  padding: 3rem 2rem;
  margin-top: -4rem !important; /* 调整无结果提示位置 */
  position: relative;
  z-index: var(--z-content);
  margin-bottom: 3rem;
}

.no-results-icon {
  font-size: 3rem;
  margin-bottom: 1rem;
}

.no-results h2 {
  margin-top: 0;
  margin-bottom: 0.5rem;
  font-size: 1.5rem;
  color: var(--text-color);
}

.no-results p {
  color: var(--text-secondary);
  margin-bottom: 1.5rem;
}

.btn-clear {
  background: var(--primary-gradient);
  border: none;
  color: white;
  padding: 0.75rem 2rem;
  border-radius: var(--radius-base);
  font-weight: 600;
  box-shadow: 0 4px 10px rgba(19, 194, 194, 0.3);
  transition: var(--transition-base);
}

.btn-clear:hover {
  box-shadow: 0 6px 15px rgba(19, 194, 194, 0.4);
  transform: translateY(-2px);
}

/* 联系支持样式 */
.contact-support {
  background: var(--primary-gradient);
  border-radius: var(--radius-lg);
  padding: 3rem 2rem;
  text-align: center;
  color: white;
  margin-bottom: 4rem;
  box-shadow: var(--shadow-lg);
}

.support-content h2 {
  margin-top: 0;
  margin-bottom: 0.5rem;
  font-size: 1.5rem;
}

.support-content p {
  opacity: 0.9;
  margin-bottom: 1.5rem;
}

.btn-contact {
  background-color: white;
  color: var(--primary-color);
  border: none;
  padding: 0.75rem 2rem;
  border-radius: var(--radius-base);
  font-weight: 600;
  transition: var(--transition-base);
}

.btn-contact:hover {
  background-color: rgba(255, 255, 255, 0.9);
  transform: translateY(-2px);
}

/* 动画效果 */
.animate-fade-up {
  opacity: 0;
  transform: translateY(30px);
  animation: fadeUp 0.8s forwards;
  animation-delay: var(--delay, 0s);
}

@keyframes fadeUp {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* 响应式设计 */
@media (max-width: 768px) {
  .header-section {
    padding: 3rem 0 6rem;
  }
  
  .category-icon {
    width: 40px;
    height: 40px;
    font-size: 1.5rem;
  }
  
  .faq-content {
    margin-top: -3rem;
  }
}

@media (max-width: 576px) {
  .header-section {
    padding: 2.5rem 0 5rem;
  }
  
  .search-input :deep(.el-input__inner) {
    height: 45px;
    font-size: 0.9rem;
  }
  
  .faq-content {
    margin-top: -2rem;
  }
  
  .category-header {
    padding: 1rem;
  }
  
  .category-icon {
    width: 36px;
    height: 36px;
    font-size: 1.2rem;
  }
  
  .category-header h2 {
    font-size: 1.1rem;
  }
  
  .faq-category :deep(.el-collapse-item__header) {
    padding: 0.75rem 1rem;
    font-size: 0.9rem;
  }
  
  .faq-category :deep(.el-collapse-item__content) {
    padding: 0.75rem 1rem 1rem;
    font-size: 0.9rem;
  }
  
  .contact-support {
    padding: 2rem 1.5rem;
  }
}
</style> 